1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 package sun.util.logging;
28
29 import java.lang.ref.WeakReference;
30 import java.lang.reflect.InvocationTargetException;
31 import java.lang.reflect.Method;
32 import java.io.PrintStream;
33 import java.io.PrintWriter;
34 import java.io.StringWriter;
35 import java.security.AccessController;
36 import java.security.PrivilegedAction;
37 import java.text.MessageFormat;
38 import java.util.Date;
39 import java.util.HashMap;
40 import java.util.Map;
41 import sun.misc.JavaLangAccess;
42 import sun.misc.SharedSecrets;
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89 public class PlatformLogger {
90
91 public static final int OFF = Integer.MAX_VALUE;
92 public static final int SEVERE = 1000;
93 public static final int WARNING = 900;
94 public static final int INFO = 800;
95 public static final int CONFIG = 700;
96 public static final int FINE = 500;
97 public static final int FINER = 400;
98 public static final int FINEST = 300;
99 public static final int ALL = Integer.MIN_VALUE;
100
101 private static final int defaultLevel = INFO;
102 private static boolean loggingEnabled;
103 static {
104 loggingEnabled = AccessController.doPrivileged(
105 new PrivilegedAction<Boolean>() {
106 public Boolean run() {
107 String cname = System.getProperty("java.util.logging.config.class");
108 String fname = System.getProperty("java.util.logging.config.file");
109 return (cname != null || fname != null);
110 }
111 });
112 }
113
114
115 private static Map<String,WeakReference<PlatformLogger>> loggers =
116 new HashMap<>();
117
118
119
120
121 public static synchronized PlatformLogger getLogger(String name) {
122 PlatformLogger log = null;
123 WeakReference<PlatformLogger> ref = loggers.get(name);
124 if (ref != null) {
125 log = ref.get();
126 }
127 if (log == null) {
128 log = new PlatformLogger(name);
129 loggers.put(name, new WeakReference<>(log));
130 }
131 return log;
132 }
133
134
135
136
137
138 public static synchronized void redirectPlatformLoggers() {
139 if (loggingEnabled || !LoggingSupport.isAvailable()) return;
140
141 loggingEnabled = true;
142 for (Map.Entry<String, WeakReference<PlatformLogger>> entry : loggers.entrySet()) {
143 WeakReference<PlatformLogger> ref = entry.getValue();
144 PlatformLogger plog = ref.get();
145 if (plog != null) {
146 plog.newJavaLogger();
147 }
148 }
149 }
150
151
152
153
154 private void newJavaLogger() {
155 logger = new JavaLogger(logger.name, logger.effectiveLevel);
156 }
157
158
159
160 private volatile LoggerProxy logger;
161
162 private PlatformLogger(String name) {
163 if (loggingEnabled) {
164 this.logger = new JavaLogger(name);
165 } else {
166 this.logger = new LoggerProxy(name);
167 }
168 }
169
170
171
172
173
174 public boolean isEnabled() {
175 return logger.isEnabled();
176 }
177
178
179
180
181 public String getName() {
182 return logger.name;
183 }
184
185
186
187
188
189 public boolean isLoggable(int level) {
190 return logger.isLoggable(level);
191 }
192
193
194
195
196
197 public int getLevel() {
198 return logger.getLevel();
199 }
200
201
202
203
204 public void setLevel(int newLevel) {
205 logger.setLevel(newLevel);
206 }
207
208
209
210
211 public void severe(String msg) {
212 logger.doLog(SEVERE, msg);
213 }
214
215 public void severe(String msg, Throwable t) {
216 logger.doLog(SEVERE, msg, t);
217 }
218
219 public void severe(String msg, Object... params) {
220 logger.doLog(SEVERE, msg, params);
221 }
222
223
224
225
226 public void warning(String msg) {
227 logger.doLog(WARNING, msg);
228 }
229
230 public void warning(String msg, Throwable t) {
231 logger.doLog(WARNING, msg, t);
232 }
233
234 public void warning(String msg, Object... params) {
235 logger.doLog(WARNING, msg, params);
236 }
237
238
239
240
241 public void info(String msg) {
242 logger.doLog(INFO, msg);
243 }
244
245 public void info(String msg, Throwable t) {
246 logger.doLog(INFO, msg, t);
247 }
248
249 public void info(String msg, Object... params) {
250 logger.doLog(INFO, msg, params);
251 }
252
253
254
255
256 public void config(String msg) {
257 logger.doLog(CONFIG, msg);
258 }
259
260 public void config(String msg, Throwable t) {
261 logger.doLog(CONFIG, msg, t);
262 }
263
264 public void config(String msg, Object... params) {
265 logger.doLog(CONFIG, msg, params);
266 }
267
268
269
270
271 public void fine(String msg) {
272 logger.doLog(FINE, msg);
273 }
274
275 public void fine(String msg, Throwable t) {
276 logger.doLog(FINE, msg, t);
277 }
278
279 public void fine(String msg, Object... params) {
280 logger.doLog(FINE, msg, params);
281 }
282
283
284
285
286 public void finer(String msg) {
287 logger.doLog(FINER, msg);
288 }
289
290 public void finer(String msg, Throwable t) {
291 logger.doLog(FINER, msg, t);
292 }
293
294 public void finer(String msg, Object... params) {
295 logger.doLog(FINER, msg, params);
296 }
297
298
299
300
301 public void finest(String msg) {
302 logger.doLog(FINEST, msg);
303 }
304
305 public void finest(String msg, Throwable t) {
306 logger.doLog(FINEST, msg, t);
307 }
308
309 public void finest(String msg, Object... params) {
310 logger.doLog(FINEST, msg, params);
311 }
312
313
314
315
316
317 static class LoggerProxy {
318 private static final PrintStream defaultStream = System.err;
319
320 final String name;
321 volatile int levelValue;
322 volatile int effectiveLevel = 0;
323
324 LoggerProxy(String name) {
325 this(name, defaultLevel);
326 }
327
328 LoggerProxy(String name, int level) {
329 this.name = name;
330 this.levelValue = level == 0 ? defaultLevel : level;
331 }
332
333 boolean isEnabled() {
334 return levelValue != OFF;
335 }
336
337 int getLevel() {
338 return effectiveLevel;
339 }
340
341 void setLevel(int newLevel) {
342 levelValue = newLevel;
343 effectiveLevel = newLevel;
344 }
345
346 void doLog(int level, String msg) {
347 if (level < levelValue || levelValue == OFF) {
348 return;
349 }
350 defaultStream.print(format(level, msg, null));
351 }
352
353 void doLog(int level, String msg, Throwable thrown) {
354 if (level < levelValue || levelValue == OFF) {
355 return;
356 }
357 defaultStream.print(format(level, msg, thrown));
358 }
359
360 void doLog(int level, String msg, Object... params) {
361 if (level < levelValue || levelValue == OFF) {
362 return;
363 }
364 String newMsg = formatMessage(msg, params);
365 defaultStream.print(format(level, newMsg, null));
366 }
367
368 public boolean isLoggable(int level) {
369 if (level < levelValue || levelValue == OFF) {
370 return false;
371 }
372 return true;
373 }
374
375
376 private String formatMessage(String format, Object... parameters) {
377
378 try {
379 if (parameters == null || parameters.length == 0) {
380
381 return format;
382 }
383
384
385
386
387
388 if (format.indexOf("{0") >= 0 || format.indexOf("{1") >=0 ||
389 format.indexOf("{2") >=0|| format.indexOf("{3") >=0) {
390 return java.text.MessageFormat.format(format, parameters);
391 }
392 return format;
393 } catch (Exception ex) {
394
395 return format;
396 }
397 }
398
399 private static final String formatString =
400 LoggingSupport.getSimpleFormat(false);
401
402
403 private Date date = new Date();
404 private synchronized String format(int level, String msg, Throwable thrown) {
405 date.setTime(System.currentTimeMillis());
406 String throwable = "";
407 if (thrown != null) {
408 StringWriter sw = new StringWriter();
409 PrintWriter pw = new PrintWriter(sw);
410 pw.println();
411 thrown.printStackTrace(pw);
412 pw.close();
413 throwable = sw.toString();
414 }
415
416 return String.format(formatString,
417 date,
418 getCallerInfo(),
419 name,
420 PlatformLogger.getLevelName(level),
421 msg,
422 throwable);
423 }
424
425
426
427 private String getCallerInfo() {
428 String sourceClassName = null;
429 String sourceMethodName = null;
430
431 JavaLangAccess access = SharedSecrets.getJavaLangAccess();
432 Throwable throwable = new Throwable();
433 int depth = access.getStackTraceDepth(throwable);
434
435 String logClassName = "sun.util.logging.PlatformLogger";
436 boolean lookingForLogger = true;
437 for (int ix = 0; ix < depth; ix++) {
438
439
440 StackTraceElement frame =
441 access.getStackTraceElement(throwable, ix);
442 String cname = frame.getClassName();
443 if (lookingForLogger) {
444
445 if (cname.equals(logClassName)) {
446 lookingForLogger = false;
447 }
448 } else {
449 if (!cname.equals(logClassName)) {
450
451 sourceClassName = cname;
452 sourceMethodName = frame.getMethodName();
453 break;
454 }
455 }
456 }
457
458 if (sourceClassName != null) {
459 return sourceClassName + " " + sourceMethodName;
460 } else {
461 return name;
462 }
463 }
464 }
465
466
467
468
469
470 static class JavaLogger extends LoggerProxy {
471 private static final Map<Integer, Object> levelObjects =
472 new HashMap<>();
473
474 static {
475 if (LoggingSupport.isAvailable()) {
476
477 getLevelObjects();
478 }
479 }
480
481 private static void getLevelObjects() {
482
483 int[] levelArray = new int[] {OFF, SEVERE, WARNING, INFO, CONFIG, FINE, FINER, FINEST, ALL};
484 for (int l : levelArray) {
485 Object level = LoggingSupport.parseLevel(getLevelName(l));
486 levelObjects.put(l, level);
487 }
488 }
489
490 private final Object javaLogger;
491 JavaLogger(String name) {
492 this(name, 0);
493 }
494
495 JavaLogger(String name, int level) {
496 super(name, level);
497 this.javaLogger = LoggingSupport.getLogger(name);
498 if (level != 0) {
499
500 LoggingSupport.setLevel(javaLogger, levelObjects.get(level));
501 }
502 }
503
504
505
506
507
508
509
510 void doLog(int level, String msg) {
511 LoggingSupport.log(javaLogger, levelObjects.get(level), msg);
512 }
513
514 void doLog(int level, String msg, Throwable t) {
515 LoggingSupport.log(javaLogger, levelObjects.get(level), msg, t);
516 }
517
518 void doLog(int level, String msg, Object... params) {
519
520
521 int len = (params != null) ? params.length : 0;
522 Object[] sparams = new String[len];
523 for (int i = 0; i < len; i++) {
524 sparams [i] = String.valueOf(params[i]);
525 }
526 LoggingSupport.log(javaLogger, levelObjects.get(level), msg, sparams);
527 }
528
529 boolean isEnabled() {
530 Object level = LoggingSupport.getLevel(javaLogger);
531 return level == null || level.equals(levelObjects.get(OFF)) == false;
532 }
533
534 int getLevel() {
535 Object level = LoggingSupport.getLevel(javaLogger);
536 if (level != null) {
537 for (Map.Entry<Integer, Object> l : levelObjects.entrySet()) {
538 if (level == l.getValue()) {
539 return l.getKey();
540 }
541 }
542 }
543 return 0;
544 }
545
546 void setLevel(int newLevel) {
547 levelValue = newLevel;
548 LoggingSupport.setLevel(javaLogger, levelObjects.get(newLevel));
549 }
550
551 public boolean isLoggable(int level) {
552 return LoggingSupport.isLoggable(javaLogger, levelObjects.get(level));
553 }
554 }
555
556 private static String getLevelName(int level) {
557 switch (level) {
558 case OFF : return "OFF";
559 case SEVERE : return "SEVERE";
560 case WARNING : return "WARNING";
561 case INFO : return "INFO";
562 case CONFIG : return "CONFIG";
563 case FINE : return "FINE";
564 case FINER : return "FINER";
565 case FINEST : return "FINEST";
566 case ALL : return "ALL";
567 default : return "UNKNOWN";
568 }
569 }
570
571 }